Створив модуль main\_control. Протестував його роботу як окремого модуля. В коді вказав куди які провідники підключаються. Залишилось не зрозумілим куди поступає сигнал о branch

| <b>\$</b> 1 <b>₹</b>            | Msgs |   |    |    |    |    |     |     |     |     |      |      |  |   |
|---------------------------------|------|---|----|----|----|----|-----|-----|-----|-----|------|------|--|---|
| <b>±</b> - <b>♦</b> op          | 43   | 0 |    |    |    |    | 2   | 4   | 8   | 9   | 35   | 43   |  | _ |
| <b>±</b> - <b>♦</b> func        | 35   |   | 32 | 33 | 34 | 35 |     |     |     |     |      |      |  |   |
| <b>±</b> - <b>∜</b> i_instrCode | 2787 | Χ | 32 | 33 | 34 | 35 | 163 | 291 | 547 | 611 | 2275 | 2787 |  |   |
| <b>±</b> - <b>♦</b> o_jump      | 0    | 0 |    |    |    |    | 1   | 2   | 0   |     |      |      |  |   |
| 💠 o_regDst                      | 0    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| o_memToReg                      | 0    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| ◆ o_ExtOp                       | 1    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| o_memWrite                      | 1    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| ◆ o_aluSrc                      | 1    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| o_regWrite                      | 0    |   |    |    |    |    |     |     |     |     |      |      |  |   |
| o_branch                        | 1    |   |    |    |    |    |     |     |     |     |      |      |  |   |
|                                 |      |   |    |    |    |    |     |     |     |     |      |      |  |   |

```
module main_control(
       i_instrCode,// from Inst_mem->{31:26, 5:0}
       o_regDst, // for mux
       o_jump,
       o_memToReg, // for mux
       o_ExtOp, // for sigbExtend->i_en
       o_memWrite, // for ram->i_we 0-read 1-write
       o_aluSrc, // for mux
       o_regWrite, // for regFile->i_ew 0-read 1-write
       o_branch // enable branch from overflow
   );
          [11:0] i_instrCode;
   input
   output reg
                     o_regDst;
   output reg [1:0] o_jump;
   output reg
                     o_memToReg;
   output reg
                    o_ExtOp;
   output reg
                    o_memWrite;
                    o_aluSrc;
   output reg
                     o_regWrite;
   output reg
   output reg
                     o_branch;
   always @(i_instrCode) begin
    //Reset
       o_regDst = 0;
       o_jump = 0;
       o_memToReg = 0;
       o_ExtOp = 0;
       o_memWrite = 0;
       o_aluSrc = 0;
       o_regWrite = 0;
       o_branch = 1;
```

```
// R-type
  if(i_instrCode[11:6]==0) begin
       case(i_instrCode[5:0])
           32: begin //add
               o_aluSrc = 0;
               o_memToReg = 0;
               o_regWrite = 1;
               o_regDst = 1;
           33: begin //addu
               o_aluSrc = 0;
               o_memToReg = 0;
               o_regWrite = 1;
               o_regDst = 1;
               o_branch = 0;
           34: begin //sub
               o_aluSrc = 0;
               o_memToReg = 0;
               o_regWrite = 1;
               o_regDst = 1;
           35: begin //subu
               o_aluSrc = 0;
               o_memToReg = 0;
               o_regWrite = 1;
               o_regDst = 1;
               o_branch = 0;
// I-type
  end else begin
      case(i_instrCode[11:6])
           2: begin
                      //jump
               o_jump = 1;
           end
           4: begin
               o_jump = 2;
               o_aluSrc = 1;
               o_ExtOp = 1;
           8: begin
               o_regDst = 0;
               o_aluSrc = 1;
               o_ExtOp = 1;
               o_memToReg = 0;
               o_regWrite = 1;
           9: begin //addiu
               o_regDst = 0;
               o_aluSrc = 1;
               o_ExtOp = 1;
               o_memToReg = 0;
```

```
o_regWrite = 1;
                   o_branch = 0;
               35: begin //lw
                   o_regDst = 0;
                   o_aluSrc = 1;
                   o_ExtOp = 1;
                   o_memToReg = 1;
                   o_regWrite = 1;
                   o_memWrite = 0;
               43: begin //sw
                   o_regDst = 0;
                   o_aluSrc = 1;
                   o_ExtOp = 1;
                   o_regWrite = 0;
                   o_memWrite = 1;
endmodule
```